﻿// Copyright Dirk Lemstra https://github.com/dlemstra/Magick.NET.
// Licensed under the Apache License, Version 2.0.

using ImageMagick;
using Xunit;

namespace Magick.NET.Tests;

public class TheBgrCoder
{
#if Q8
    private readonly byte[] _bytes = new byte[] { 1, 2, 3, 4 };
#else
    private readonly byte[] _bytes = new byte[] { 1, 0, 2, 0, 3, 0, 4, 0 };
#endif

    private readonly MagickReadSettings _settings = new MagickReadSettings
    {
        Width = 1,
        Height = 1,
    };

    [Fact]
    public void ShouldSetTheCorrectValueForTheAlphaChannel()
    {
        _settings.Format = MagickFormat.Bgra;
        using var image = new MagickImage(_bytes, _settings);
        using var pixels = image.GetPixels();

        var pixel = pixels.GetPixel(0, 0);
        Assert.Equal(4, pixel.Channels);
        Assert.Equal(3, pixel.GetChannel(0));
        Assert.Equal(2, pixel.GetChannel(1));
        Assert.Equal(1, pixel.GetChannel(2));
        Assert.Equal(4, pixel.GetChannel(3));
    }

    [Fact]
    public void ShouldSetTheCorrectValueForTheOpacityChannel()
    {
        _settings.Format = MagickFormat.Bgro;
        using var image = new MagickImage(_bytes, _settings);
        using var pixels = image.GetPixels();
        var pixel = pixels.GetPixel(0, 0);

        Assert.Equal(4, pixel.Channels);
        Assert.Equal(3, pixel.GetChannel(0));
        Assert.Equal(2, pixel.GetChannel(1));
        Assert.Equal(1, pixel.GetChannel(2));
        Assert.Equal(Quantum.Max - 4, pixel.GetChannel(3));
    }
}
